﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using STT.Business;
using STT.Entities;
using System.Data;
using System.Text;
using System.Data.OleDb;
using System.Data.SqlClient;
using System.IO;


namespace STT.Admin.UserControls
{
    public partial class ucPhongBan : System.Web.UI.UserControl
    {
        public bool chonSuaClick;
        bool KiemTraRong;
        bool KiemTraTonTai;
        List<string> error;
        string count;
        protected void Page_Load(object sender, EventArgs e)
        {
            LoadPhongBan();
             
            chonSuaClick = false;
            
        }
        void LoadPhongBan()
        {
            gvPhongBan.AutoGenerateColumns = false;
            gvPhongBan.DataSource = BTbPhongBan.SelectAll1();
            gvPhongBan.DataBind();
        }
        bool KiemTraDuLieu()
        {
            return BTbPhongBan.KiemTraDuLieu(new ETbPhongBan
            {
                TenPB = txtTenPB.Text
              
            });
        }
        bool KiemTraDuLieu_Sua()
        {
            return BTbPhongBan.KiemTraDuLieu_Sua(new ETbPhongBan
            {
                TenPB = txtTenPB.Text,
                MaPB = Int32.Parse(hfMaPhongBan.Value)
            });
        }
        void ThongBao(string Loi)
        {
            ScriptManager.RegisterClientScriptBlock(this, GetType(), "Thông báo!", "<script>alert('" + Loi + "')</script>", false);
        }
        protected void gvPhongBan_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            if (e.CommandName == "ChonSua")
            {
                // Lay id
                int index = Convert.ToInt32(e.CommandArgument);
                hfMaPhongBan.Value = gvPhongBan.DataKeys[index].Value.ToString();
                // Thay đổi tiêu đề
                txtTieuDe.InnerText = "Sửa Phòng ban";
                txtTenPB.Text = HttpUtility.HtmlDecode(gvPhongBan.Rows[index].Cells[1].Text);
                txtDiaChi.Text = HttpUtility.HtmlDecode(gvPhongBan.Rows[index].Cells[2].Text);
                txtTruongPhong.Text = HttpUtility.HtmlDecode(gvPhongBan.Rows[index].Cells[3].Text);
                txtSoNhanVien.Text = HttpUtility.HtmlDecode(gvPhongBan.Rows[index].Cells[4].Text);
                Label tt = ((Label)gvPhongBan.Rows[index].Cells[5].FindControl("lblTrangThai"));
                if (tt.Text == "Sử dụng")
                {
                    ddTrangThai.SelectedValue = "1";
                }
                else
                { ddTrangThai.SelectedValue = "0"; }

                 
                 
                chonSuaClick = true;
            }
        }

        protected void lbXoaTat_Click(object sender, EventArgs e)
        {
            try
            {
                for (int i = 0; i < gvPhongBan.Rows.Count; i++)
                {
                    CheckBox cbChon = (CheckBox)gvPhongBan.Rows[i].Cells[0].FindControl("cbChon");
                    if (cbChon != null && cbChon.Checked)
                    {
                        BTbPhongBan.Delete(int.Parse(gvPhongBan.DataKeys[i].Value.ToString()));
                    }
                }

                LoadPhongBan();
                Session["action"] = 3;
            }
            catch
            {
                ThongBao("Dữ liệu liên quan đến một số Phòng ban vẫn tồn tại, vui lòng kiểm tra lại dữ liệu!");
            }
        }

        protected void lbXuatDuLieu_Click(object sender, EventArgs e)
        {

        }

        protected void btThemMoi_Click(object sender, EventArgs e)
        {
            if (!KiemTraDuLieu())
            {
                BTbPhongBan.Insert(new ETbPhongBan
                {
                    TenPB = txtTenPB.Text,
                    DiaChiPB = txtDiaChi.Text,
                    TruongPB = txtTruongPhong.Text,
                    SoNV = Int32.Parse(txtSoNhanVien.Text),
                    TrangThai = Int32.Parse(ddTrangThai.SelectedValue)
                });
                LoadPhongBan();
                Session["action"] = 1;
            }
            else
            {
                ThongBao("Phòng ban này đã tồn tại!");
            }
        }

        protected void btSearch_Click(object sender, ImageClickEventArgs e)
        {
            DataTable dt = new DataTable();
            dt = BTbPhongBan.SearchPhongBan(new ETbPhongBan
            {
                TenPB = txtTimKiem.Text
            });
            gvPhongBan.DataSource = dt;
            gvPhongBan.DataBind();
        }

        protected void btThemExcel_Click(object sender, EventArgs e)
        {
            if (FileUpload.HasFile)
            {
                error = new List<string>();
                string filename = FileUpload.FileName;
                string[] str = FileUpload.FileName.Split('.');
                string ten = str[0];
                string duoi = str[1];
                if (duoi == "xls" || duoi == "xlsx")
                {
                    string path = string.Concat(Server.MapPath("~/uploads/files/" + DateTime.Now.ToString("yyyymmddhhmmssfff") + ten + "." + duoi));
                    FileUpload.PostedFile.SaveAs(path);
                    OleDbConnection oledbcon = new OleDbConnection("provider=microsoft.ace.oledb.12.0;data source=" + path + ";extended properties=excel 12.0;");
                    OleDbCommand command = new OleDbCommand("select * from [sheet1$]", oledbcon);
                    OleDbDataAdapter objadapter1 = new OleDbDataAdapter(command);
                    oledbcon.Open();
                    DataTable dt = new DataTable();
                    DataTable dt1 = BTbPhongBan.SelectAll();
                    objadapter1.Fill(dt);
                    if (dt.Rows.Count > 0)
                    {
                        for (int i = 0; i < dt.Rows.Count; i++)
                        {
                            KiemTraRong = true;
                            KiemTraTonTai = true;
                            //for (int o = 0; o < dt.Columns.Count; o++)
                            //{
                                KiemTraRong = true;
                                if (dt.Rows[i][1].ToString().Trim().Equals(""))
                                {
                                    KiemTraRong = false;
                                    error.Add("Lỗi bỏ trống Phòng ban thứ " + dt.Rows[i][0].ToString() + "!");
                                    continue;
                                }
                            //}
                            //if (dt.Rows[i][1].ToString() == "")
                            //{
                            //    KiemTraRong = false;
                            //    error.Add("Lỗi bỏ trống Phòng ban thứ " + dt.Rows[i][0].ToString() + "!");
                            //    continue;
                            //}
                            for (int j = 0; j < dt1.Rows.Count; j++)
                            {
                                KiemTraTonTai = true;
                                if (dt.Rows[i][1].ToString().ToLower().Trim() == dt1.Rows[j][1].ToString().ToLower().Trim())
                                {
                                    KiemTraTonTai = false;
                                    error.Add("Phòng ban " + dt.Rows[i][1].ToString() + " đã tồn tại!");
                                    break;
                                }
                                
                            }
                            if (KiemTraRong && KiemTraTonTai)
                            {
                                //try
                                //{
                                    BTbPhongBan.Insert(new ETbPhongBan
                                    {
                                        TenPB = dt.Rows[i][1].ToString(),
                                        DiaChiPB = dt.Rows[i][2].ToString(),
                                        TruongPB = dt.Rows[i][3].ToString(),
                                        SoNV = Int32.Parse(dt.Rows[i][4].ToString().Trim()),
                                        TrangThai = 1
                                    });
                                //}
                                //catch (Exception ex)
                                //{
                                //    Response.Write("");
                                //}
                            }
                        }
                        for (int i = 0; i < error.Count; i++)
                        {
                            count += " + " + error[i].ToString() + "<br/>";
                        }
                        if (error.Count > 0)
                        {
                            plError.Visible = true;
                            lbError.Text = "Bạn kiểm tra lại thông tin Phòng ban:" + "<br/>" + count;
                        }
                    }
                    oledbcon.Close();
                }
                else
                {
                    ThongBao("Tệp tin không đúng định dạng Excel!");
                }
            }
            else
            {
                ThongBao("Bạn chưa tải tệp tin!");
            }
            LoadPhongBan();
            Session["action"] = 1;
        }

        protected void btSua_Click(object sender, EventArgs e)
        {
            if (!KiemTraDuLieu_Sua())
            {
                BTbPhongBan.Update(new ETbPhongBan
                {
                    MaPB = Int32.Parse(hfMaPhongBan.Value),
                    TenPB = txtTenPB.Text,
                    DiaChiPB = txtDiaChi.Text,
                    TruongPB = txtTruongPhong.Text,
                    SoNV = Int32.Parse(txtSoNhanVien.Text),
                    TrangThai = Int32.Parse(ddTrangThai.SelectedValue)
                });
                LoadPhongBan();
                Session["action"] = 2;
            }
            else
            {
                ThongBao("Vui lòng kiểm tra lại dữ liệu , dữ liệu đã tồn tại !");
            }
      
        }

        protected void gvPhongBan_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            try
            {
                int MaPhongBan = int.Parse(gvPhongBan.DataKeys[e.RowIndex].Value.ToString());

                BTbPhongBan.Delete(MaPhongBan);
                LoadPhongBan();
                Session["action"] = 3;
            }
            catch
            {
                ThongBao("Dữ liệu liên quan đến Phòng ban này vẫn tồn tại, vui lòng kiểm tra lại dữ liệu!");
            }
        }

        protected void gvPhongBan_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {
            gvPhongBan.PageIndex = e.NewPageIndex;
            gvPhongBan.DataBind();
        }

       
    }
}